home *** CD-ROM | disk | FTP | other *** search
/ The Atari Compendium / The Atari Compendium (Toad Computers) (1994).iso / files / umich / network / ka9q / ka9q_src.arc / TCP.H < prev    next >
C/C++ Source or Header  |  1988-07-28  |  5KB  |  163 lines

  1. /* TCP implementation. Follows RFC 793 as closely as possible */
  2.  
  3. #define    DEF_WND    2048    /* Default receiver window */
  4. #define    NTCB    19    /* # TCB hash table headers */
  5. #define    DEF_MSS    512    /* Default maximum segment size */
  6. #define    DEF_RTT    5    /* Initial guess at round trip time (5 sec) */
  7. #define    MSL2    30    /* Guess at two maximum-segment lifetimes */
  8. /* Round trip timing parameters */
  9. #define    ALPHA1    7    /* 7/8 when delay is increasing */
  10. #define    ALPHA2    15    /* 15/16 when delay is decreasing */
  11. #define    BETA    2    /* Allow two round trip times before retransmitting */
  12.  
  13. /* TCP segment header -- internal representation
  14.  * Note that this structure is NOT the actual header as it appears on the
  15.  * network (in particular, the offset and checksum fields are missing).
  16.  * All that knowledge is in the functions ntohtcp() and htontcp() in tcpsubr.c
  17.  */
  18. struct tcp {
  19.     int16 source;    /* Source port */
  20.     int16 dest;    /* Destination port */
  21.     int32 seq;    /* Sequence number */
  22.     int32 ack;    /* Acknowledgment number */
  23.     char flags;    /* Flags, data offset */
  24. #define    URG    0x20    /* URGent flag */
  25. #define    ACK    0x10    /* ACKnowledgment flag */
  26. #define    PSH    0x08    /* PuSH flag */
  27. #define    RST    0x04    /* ReSeT flag */
  28. #define    SYN    0x02    /* SYNchronize flag */
  29. #define    FIN    0x01    /* FINal flag */
  30.     int16 wnd;    /* Receiver flow control window */
  31.     int16 up;    /* Urgent pointer */
  32.     int16 mss;    /* Optional max seg size */
  33. };
  34. /* TCP options */
  35. #define    EOL_KIND    0
  36. #define    NOOP_KIND    1
  37. #define    MSS_KIND    2
  38.  
  39. #define    TCPLEN        20
  40. #define    MSS_LENGTH    4
  41. /* Resequencing queue entry */
  42. struct reseq {
  43.     struct reseq *next;    /* Linked-list pointer */
  44.     char tos;        /* Type of service */
  45.     struct tcp seg;        /* TCP header */
  46.     struct mbuf *bp;    /* data */
  47.     int16 length;        /* data length */
  48. };
  49. #define    NULLRESEQ    (struct reseq *)0
  50.  
  51. /* TCP connection control block */
  52. struct tcb {
  53.     struct tcb *prev;    /* Linked list pointers for hash table */
  54.     struct tcb *next;
  55.  
  56.     struct connection conn;
  57.  
  58.     char state;    /* Connection state */
  59. #define    CLOSED        0    /* Must be 0 */
  60. #define    LISTEN        1
  61. #define    SYN_SENT    2
  62. #define    SYN_RECEIVED    3
  63. #define    ESTABLISHED    4
  64. #define    FINWAIT1    5
  65. #define    FINWAIT2    6
  66. #define    CLOSE_WAIT    7
  67. #define    CLOSING        8
  68. #define    LAST_ACK    9
  69. #define    TIME_WAIT    10
  70.  
  71.     char reason;        /* Reason for closing */
  72. #define    NORMAL        0    /* Normal close */
  73. #define    RESET        1    /* Reset by other end */
  74. #define    TIMEOUT        2    /* Excessive retransmissions */
  75. #define    NETWORK        3    /* Network problem (ICMP message) */
  76.  
  77. /* If reason == NETWORK, the ICMP type and code values are stored here */
  78.     char type;
  79.     char code;
  80.  
  81.     /* Send sequence variables */
  82.     struct {
  83.         int32 una;    /* First unacknowledged sequence number */
  84.         int32 nxt;    /* Next sequence num to be sent for the first time */
  85.         int32 ptr;    /* Working transmission pointer */
  86.         int16 wnd;    /* Other end's offered receive window */
  87.         int16 up;    /* Send urgent pointer */
  88.         int32 wl1;    /* Sequence number used for last window update */
  89.         int32 wl2;    /* Ack number used for last window update */
  90.     } snd;
  91.     int32 iss;        /* Initial send sequence number */
  92.  
  93.     /* Receive sequence variables */
  94.     struct {
  95.         int32 nxt;    /* Incoming sequence number expected next */
  96.         int16 wnd;    /* Our offered receive window */
  97.         int16 up;    /* Receive urgent pointer */
  98.     } rcv;
  99.     int32 irs;        /* Initial receive sequence number */
  100.     int16 mss;        /* Maximum segment size */
  101.  
  102.     char retry;        /* Retransmission retry count */
  103.     char backoff;        /* Backoff interval (distinct from retry) */
  104.     void (*r_upcall)();    /* Call when "significant" amount of data arrives */
  105.     void (*t_upcall)();    /* Call when ok to send more data */
  106.     void (*s_upcall)();    /* Call when connection state changes */
  107.     char flags;        /* Control flags */
  108. #define    FORCE    1        /* We owe the other end an ACK or window update */
  109. #define    CLONE    2        /* Server-type TCB, cloned on incoming SYN */
  110. #define    RETRAN    4        /* A retransmission has occurred */
  111.     char tos;        /* Type of service (for IP) */
  112.  
  113.     int16 window;        /* Receiver window and send queue limit */
  114.     struct mbuf *rcvq;    /* Receive queue */
  115.     int16 rcvcnt;
  116.  
  117.     struct mbuf *sndq;    /* Send queue */
  118.     int16 sndcnt;        /* Number of unacknowledged sequence numbers on
  119.                  * send queue. NB: includes SYN and FIN, which don't
  120.                  * actually appear on sndq!
  121.                  */
  122.     struct reseq *reseq;    /* Out-of-order segment queue */
  123.  
  124.     struct timer timer;    /* Retransmission timer */
  125.  
  126.     struct timer rtt_timer;    /* Round trip timer */
  127.     int32 rttseq;        /* Sequence number being timed */
  128.     int32 srtt;        /* Smoothed round trip time, milliseconds */
  129.  
  130.     char *user;        /* User parameter (e.g., for mapping to an
  131.                  * application control block
  132.                  */
  133. };
  134. #define    NULLTCB    (struct tcb *)0
  135. /* TCP statistics counters */
  136. struct tcp_stat {
  137.     int16 runt;        /* Smaller than minimum size */
  138.     int16 checksum;        /* TCP header checksum errors */
  139.     int16 conout;        /* Outgoing connection attempts */
  140.     int16 conin;        /* Incoming connection attempts */
  141.     int16 resets;        /* Resets generated */
  142.     int16 bdcsts;        /* Bogus broadcast packets */
  143. };
  144. extern struct tcp_stat tcp_stat;
  145.  
  146. extern struct tcb *tcbs[];
  147. extern int32 iss();
  148. struct tcb *lookup_tcb();
  149. struct tcb *create_tcb();
  150. void rehash_tcb(),tcp_output(),tcp_input(),close_self(),dump_seg(),
  151.     setstate();
  152. struct mbuf *htontcp();
  153.  
  154. /* TCP primitives */
  155. struct tcb *open_tcp();
  156. int send_tcp(),recv_tcp(),close_tcp(),del_tcp();
  157. void state_tcp(),tcp_dump();
  158.  
  159. extern int16 tcp_mss;
  160. extern int16 tcp_window;
  161. extern int16 tcp_irtt;
  162.  
  163.